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Abstract 

Complementation of finite automata on infinite words is not only a fundamental problem 
in automata theory, but also serves as a cornerstone for solving numerous decision problems 
in mathematical logic, model-checking, program analysis and verification. For Streett comple- 
mentation, a significant gap exists between the current lower bound 2 fi ( nlgnfe ) and upper bound 
2°(™ fcl s nfe ) ; where n is the state size, k is the number of Streett pairs, and k can be as large as 
2™. Determining the complexity of Streett complementation has been an open question since the 
late '80s. In this paper show a complementation construction with upper bound 2°(™ lgn+nfclg;c ) 
for k — 0(n) and 2 0<Jl lg ™- 1 for k = Ui(n), which matches well the lower bound obtained in [3]. 
We also obtain a tight upper bound 2°( Illg ") for parity complementation. 

1 Introduction 

Automata on infinite words (o;-automata) have wide applications in synthesis and verification of 
reactive concurrent systems. Complementation plays a fundamental role in many of these applica- 
tions, especially in solving the language containment problem: whether a language recognized by 
automaton A is contained by another language represented by automaton B, which is equivalent to 
whether the language of A and the complementary language of B intersect. In automata-theoretic 
model checking [101 127j . both system behaviors and logical specifications are represented as formal 
languages, and model checking by and large amounts to solving the corresponding language con- 
tainment problem. As both language intersection and emptiness test are rather easy, the efficiency 
of complementation becomes crucial to practical deployment of model-checking tools. For this 
reason and many others, determining the state complexity of the complementation problem has 
been extensively studied in the last four decades |26j. 



Related Work, w-automata were invented by Biichi in 1962 as a method of attack on defin- 
ability and decision problems for monadic second order logic on arithmetics (SIS) pQ. That type 
of w-automata are nowadays called Biichi automata. The initial Biichi complementation was not 
explicitly constructive and required double exponential blow-up pQ. But since then Biichi comple- 
mentation has been extensively studied. The upper bound was continuously improved to 2°( n ) |24| . 
2 0{n\ g n) ^ 0((6n) n ) p], O((0.97n) n ) [6] and finally to 0(n 2 L(n)) where L(n) « (0.76n) n [23], 
which matched well the lower bound f2(L(n)) [28]. 

Complementation for automata with rich acceptance conditions, such as Rabin automata and 
Streett automata, is much more sophisticated. Kupferman and Vardi showed a 2°( nfclgri ) comple- 
mentation construction for Rabin automata [14], and we showed this construction is essentially 



optimal (2J. This leaves Streett complementation the last classical problem where the gap be- 
tween the lower and upper bounds is substantial. Besides that, Streett complementation has an 
importance of its own. Streett automata share identical algebraic structures with Biichi automata, 
except being equipped with richer acceptance conditions. A Streett acceptance condition comprises 
a finite list of indexed pairs of sets of states. Each pair consists of an enabling set and a fulfilling 
set. A run is accepting if for each pair, if the run visits states in the enabling set infinitely often, 
then it also visits states in the fulfilling set infinitely often. This naturally corresponds to the 
strong fairness condition that infinitely many requests are responded infinitely often, a necessary 
requirement for meaningful computations Ej. Another advantage of Streett automata is that 
they are much more succinct than Biichi automata; it is unavoidable in the worst case to have 
2 n state blow-up to translate a Streett automaton with 0(n) states and 0(n) index pairs to an 
equivalent Biichi automaton [25J. An interesting question is: to what extent does the gain from 
the succinctness have to be paid back at the time of complementation? 

The first construction for Streett complementation was given by Safra and Vardi, and that 
construction required 2°( (nA: ) J ) state blow-up [25]. Klarlund improved this bound to 2°( nklgnk * > [8]. 
The same bound was achieved by Safra via determinization [22J, by Piterman with an improved 
determinization construction |19j . and by Kupferman and Vardi |14| . However, so far no con- 
struction has been proved to cost less than 2°( nfclgnfc ) states. The question of whether Streett 
complementation can be further improved from 2°( nfclgnfc ) has been constantly raised in the recent 
literature [14|, [28| [26] . In this paper we answer this question affirmatively 

Ranking-based Complementation. A Ranking-based complementation was first proposed by 
Klarlund [8]. Klarlund's Biichi complementation (resp. Streett complementation) relies on quasi 
co-Biichi measure (resp. quasi Rabin measure), which is a ranking function on states in a run graph, 
measuring the progress of a run toward being accepted. By this complementation scheme, Klarlund 
gave a 2°( nlgn ) Biichi complementation and a 2°( nfclgnfc ) Streett complementation [8J. Kupferman 
and Vardi developed a similar idea into an elegant and comprehensive framework |13[ 19]. obtaining 
complementation constructions for Biichi [11] , generalized Biichi [12) . Rabin and Streett [14] . 

Our Results. Our Streett complementation is obtained by improving Kupferman and Vardi's 
construction in [TJ]. We show that the larger the Rabin index size k, the higher the correlation be- 
tween infinite paths in a run graph satisfying a universal Rabin condition (the dual of an existential 
Streett condition), and characterize the correlation using two tree structures: ITS (Increasing Tree 
of Sets) and TOP (Tree of Ordered Partitions), both with elegant combinatorial properties. We 
show that our construction renders a upper bound U(n,k), which is 2°( nlgn+nfclgfc ) for k = 0(n) 
and 2 ( n2lgn ) for k = uj(n). U(n,k) is a significant improvement from the previous best bound 
when k = u(n). Speaking loosely, we gain succinctness without paying a dramatically higher price 
for complementation. U(n,k) also matches the lower bound L(n,k), which is 2^( nlgn+nfclgfc ) for 
k = 0(n) and 2^ n lgn ) for k = ui(n) [3]. By a similar technique, we also obtain a 2°( nlgn ) upper 
bound for parity complementation, which is essentially optimal, as parity automata generalizes 
Biichi automata, whose complementation lower bound is 2^( nlgn ) |17[ 115] , This is surprising as 
the index size k (though small as k < [(n + l)/2j) has no appearance in the asymptotical bound. 
We believe this is of practical interest as well, because it tells us that parity automata provide a 
richer acceptance condition without incurring an asymptotically higher cost on complementation. 
Combining the result with the one in [3] and previous findings in the literature, we now have a com- 
plete characterization of complementation complexity for w-automata of common types. Figure [U 
summarizes these results. 
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Figure 1: The complementation complexities for w-automata of common types. Note that co- 
Biichi and generalized co-Biichi automata are not listed here because they are not complete for 
w-regular languages, i.e., the class of w-languages that can be recognized by co-Biichi automata (or 
generalized co-Biichi automata) is a proper subclass of w-regular languages. 

Paper Organization. Section [2] introduces basic notations and terminology in automata the- 
ory. Section [3] presents the framework of ranking based complementation; it introduces Biichi 
complementation [11], generalized Biichi complementation [12] and Streett complementation [14] . 
Section H] presents our Streett complementation construction and Section [5] proves its complexity. 
Section [6] establishes a tight upper bound for parity complementation. Section [7] concludes with a 
discussion of future work. All proofs are placed in the appendix. 

2 Preliminaries 

Basic Notations. Let N denote the set of natural numbers. We write [i.-j] for {k € N | i < k < 
j}, for - 1], [n] for [0..n), and [n] even and [n] odd for even numbers and odd numbers in 
[n], respectively. For an infinite sequence g, we use g(i) to denote the i-th component for i £ N. 
For a finite sequence a, we use \a\ to denote the length of a, a[i] (i S [l..|a|]) to denote the object 
at the i-th position, and a[i..j] (resp. a[i..j)) to denote the subsequence of a from position i to 
position j (resp. j — 1). When we compare finite sequences of numbers, >m,>m,=m,<m,<m 
mean the corresponding standard lexicographical orderings up to position m. We reserve n and 
k as parameters of complementation instances (n for state size and k for index size), and define 
[i = min(n, k) and I = [l..k]. 

Automata and Runs. A finite automaton on infinite words (^-automaton) is a tuple A = 
(£, Q, Qq, A, J 7 ) where £ is an alphabet, Q is a finite set of states, Qq C Q is a set of initial states, 
ACQxSxQisa set of transitions, and T is an acceptance condition. 

An infinite word (w-word) over E is an infinite sequence of letters in E. A run g of A over an 
w-word w is an infinite sequence of states in Q such that g(0) € Qo and, (g(i),w(i), g(i+l)) € A for 
i 6 If. Let Inf(^) be the set of states that occur infinitely many times in g. An automaton accepts 
it? if a run g over w exists that satisfies J 7 , which is usually defined as a predicate on Inf(^). The 
language of A, written «Sf(^4), is the set of uj- words accepted by A. 

Acceptance Conditions and Types, w-automata are classified according to their acceptance 
conditions. Below we list automata of common types. Let G and B be functions from I to 2®. 

• Generalized Biichi: (B)f. Mi G I,Inf(g) n B(i) ^ 0. 

• Biichi: (B)j with I = {1} (i.e., k = 1). 
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• Streett: (G, B)j: Mi G /, lnf(g) n G(i) + -»• Inf(p) n ^ 0. 



• Par%: (G, B) / with C G(l) C • • • C B(Jfe) C G(k). 

• Generalized co-Biichi: [B]j: 3i G /, Inf(^) Pi B(i) = 0. 

• Co-Biichi: [B]j with I = {1} (i.e., k = 1). 

• Rabin: [G, 5]/: 3z G I, Inf(p) n G(») / A In%) n = 0. 

We use GB, B, S, P, GC, CB, and R, respectively, to denote the above acceptance conditions. By 
T-automata we mean the w-automata with T-condition. Note that B and CB, GB and GC, and S 
and R are dual to each other, respectively. Also note that generalized Biichi and parity automata 
are both subclasses of Streett automata, and so are generalized co-Biichi and parity automata to 
Rabin automata. Let J C I. We use [G,B]j to denote the Rabin condition with respect to only 
indices in J. When J is a singleton, say J = {j}, we simply write [G(j), B(j)] for [G,B]j. The 
same convention is used for other conditions. For a Streett condition (G, B)j, we can assume that 
B is injective, because if B(i) = B(i') for two different G /, then we can replace {G, B)uji\ by 
(G(i) U G(i'),B(i)). The same assumption is made for any Rabin condition [G,B]i. 

A-Graphs. A A-graph of an a;- word w under A is a directed graph & w = (V, E) where V = Q x N 
and E = {((q,l), (q',l + 1)} G V x V \ q, q' G Q, i G N, (q,w(i),q') G A}. By the i-th level, we 
mean the vertex set Q x {i}. Let S be a subset of Q. We call a vertex v = (q, I) S-vertex if q G S. 
When level index is of no importance in the context, we use q and v interchangeably. In particular, 
by an abuse of notation we write v G S to mean v = (q, I) for some I G N and q G S. A-graphs for 
finite words are similarly defined. The length of a finite A-graph is the number of levels minus 1. 
By unit A-graphs we mean A-graphs of length 1. A unit A-graph encodes all possible transitions 
upon reading a letter. By width of & w (written width(& w )) we mean the maximum number of 
pairwise non-intersecting infinite paths in @ w . Clearly, for any w, width(& w ) < \Q\. 

3 Ranking-based Complementation 

In this section we introduce ranking-based complementation constructions developed by Klarlund, 
Kupferman and Vardi [SI dU [HI E] . Note that all complexity related notions are parameterized 
with n and k, but we do not list them explicitly unless required for clarity. We adopt the following 
naming convention: when we talk about behaviors of a source automaton, a T-condition means an 
existential one (i.e., a path in a A-graph that satisfies T), while in the context of complementation, 
a T-condition means a universal one (i.e., every path in a A-graph satisfies T). 

Ranking-based Complementation Scheme. Let A be a T-automaton and CA a purported 
Biichi automaton that complements A. An w-word w is accepted by A if and only if the A- 
graph @ w contains an infinite path that satisfies the T-condition. Consequently, w is accepted by 
CA if and only if all paths in ^ w satisfy the dual co-T condition (for short, < S W is co-T accepting). 
Complementation essentially amounts to transforming a universal co-T condition into an existential 
Biichi condition. Rankings on A-graphs provide a solution; & w satisfying a universal co-T condition 
is precisely captured by the existence of a so-called odd co-T ranking on & w . Complementation 
then reduces to recognition of A-graphs that admit odd co-T rankings. 

The general scheme goes as follows. Vertices of ^ w are associated with certain values. The 
association at a level can be viewed as a function with domain Q (with level indices dropped), 
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called co-T level ranking. The values in the range of a co-T level ranking are called co-T ranks, 
and the n-tuple of co-T ranks at a level is called a co-T level rank. By a co-T ranking we mean an 
w-sequence of co-T level rankings, each of which is associated with a level in . Co-T rankings 
are required to satisfy a local property, which holds between every two adjacent levels and is solely 
defined with respect to the unit A-graph of the two levels. The local property therefore can be 
enforced in a step-by-step check by the transitions of CA. But the local property itself is not enough 
to ensure that a co-T condition holds universally. A special kind of co-T ranking, called odd co-T 
ranking, is singled out. A co-T ranking is odd if and only if every path visits certain vertices (called 
odd vertices) infinitely many times. This global property can be captured by a Biichi condition, 
using the Miyano-Hayashi breakpoint technique for universality (alternation) elimination [16 1. 

Let A = (Q, Qo, S, A, F T ) be a source T-automaton. The complementation algorithm produces 
a target Biichi automaton CA = (Q', Q' Q , T,, A', (F')}. The state set Q' is 2 Q x 2 Q x K, where for 
{S,0,g} € Q', S records the reachable states, O C S records the reachable states that have an 
obligation to visit odd vertices in the future, and g is a guessed co-T level ranking, all at the current 
level. The transition function A' : Q' — > 2® is defined such that A'((S,0,g)) is 

{ <A(5, a), A(0, a) \ odd{g'),g') : g 1 € Succ{g, S, a)} (O + 0), (1) 

{ (A(S, a), A(S, a) \ odd(g'),g') : g' 6 Succ(g, S, a)} (O = 0), (2) 

where Succ(g, S, a) returns the set of legitimate level rankings provided that the current level 
ranking is g and the current letter is a, and odd(g') gives the set of odd vertices at the level ranked 
by g' ■ When CA reads the letter w(i) at level i with a level ranking fi and reachable state set 
Si, it nondeterministically guesses a level ranking fi + \ such that fi + \ G Succ(fi,Si,w(i)). The 
evolvement of both S and O are done by the classic subset construction |20j with the exception 
that odd vertices are excluded from O (see u \odd(g') v in ([TJ and ([2])). Once O becomes empty, 
it takes the value of the current S in the next stage (see the second S in ([2])). The final state set 
F' is 2^ x {0} x 1Z. This Biichi condition (F') requires that O be cleared infinitely often, which 
in turn enforces that every path visits odd vertices infinitely many times [16J. It is now clear that 
Succ represents the local property (being co-T) and T' captures the global property (being odd). 

Procedure 1 (Generic Complementation). 

In-put: T -automaton A = {T>,Q,Qo,A,F T }. Output: Biichi automaton C A = (S, Q' , Q' , A', (F')): 

Q' = 2 Q x 2 Q x Tl, Q' Q = Q x {0} x 71, 

A' : Q' -> 2 Q ' defined as in © and ©, F' = 2 Q x {0} x 1Z. 

The state complexity of complementation is \Q'\. For every instantiation shown below, \R\ 
dominates 2^' and hence the complexity is 0(|7£|). 

We now show complementation constructions for Biichi, GB and Streett, with the corresponding 
co-T rankings being co-Biichi, GC and Rabin, respectively. We use V T to denote the set of T-ranks, 
1Z T the set of T level rankings and C T the set of level ranks. Clearly, \1Z T \ = \C T \. 

Biichi Complementation Let A = (Q,Qo,Y>,A,{F)) be a Biichi automaton. & w is co-Biichi 
accepting if every path in 9? w visits T-vertices finitely often. Let X> CB (the set of co-Biichi ranks) 
be [2n + l]. 

Definition 1 (Co-Biichi Ranking). A co-Biichi ranking on W w is a function f : V —> T> such 
that: 
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for all vertices v G V, if f(v) G [2n] odd ; then v £ F; 
02 for all edges (v,v') G E, f(v) > /(«'). 

A vertex u G V is odd if G [2n] odd . A co-Biichi ranking / is odd if every path in 9? w 
visits infinitely many odd vertices. A path g stabilizes at a rank r if (3i G N)(Vj > i),f(g(j)) = 
/(&(*)) = r an d the smallest such z is called the stabilization point of £>. If ^ admits an odd 
co-Biichi ranking /, then by (|112p every path eventually stabilizes at an odd rank. Then by (|1UD , 
every path eventually does not visit F-vertices; that is, & w is co-Biichi accepting. 

Conversely, if & w is co-Biichi accepting, then an odd co-Biichi ranking can be constructed 
through a series of graph transformations. Let % = &w Vertices with only a finite number of 
descendants are called finite. Vertices that are not F-vertices and have no F-vertices as their 
descendants are called F-free. At stage 0, we assign all finite vertices rank and remove them, 
obtaining Sfi, in which there is no finite vertices. Because % is co-Biichi accepting, there must 
exist in S^i an .F-free vertex; otherwise we can select a path on which F-vertices occur infinitely 
often. We assign all F-free vertices rank 1 and remove them too, obtaining Now some vertices 
in ^2 are finite due to the removal of F-free vertices in stage 0. We repeat this process in the 
following manner: at the first phase of stage i, we assign even rank 2i to finite vertices and remove 
them; at the second phase, we assign F-free vertices odd rank 2i + 1 and remove them. By 
F-freeness, removing F-free vertices from S^i+i gets rid of at least one infinite path, and hence 
width{ ( ^2i+2) < width (^Sn). Therefore, this process terminates at a stage j < n. In the following 
summary, by & \ V we mean removing from 5f all vertices in V and their incoming and outgoing 
edges. 

Procedure 2 (Co-Biichi Ranking Assignment). 

Input: a co-Biichi accepting Output: a co-Biichi ranking f. Repeat for i G [0..n] if^n 7^ 0- 



Lemma 1 ( S W is co-Biichi accepting if and only if£ w admits an odd co-Biichi ranking. 

We have |£> CB | = O(n), and hence |ft CB | = (0(n)) n = 2°^ n \ 

GB Complementation Let A = (Q, Qo, S, A, (B)j) be a generalized Biichi automaton. GC 
ranking is meant to be used for GB complementation. A @ w is GC accepting if for every path g in 
@ w there exists j £ I such that g only visits 5(j)-vertices finitely often. Let D GC = ([2n] odd x 7) U 
[2n + l] even be the set of GC ranks. We refer to values in [2n] odd x / as odd ranks, and values in 
[2n + l] even as even ranks. For an odd GC rank (t, u), we call t numeric rank (r-rank) and u index 
rank (/i-rank). Even GC ranks are just numeric ranks. The greater-than and less-than orders on 
GC ranks are solely defined on r-ranks. For example, (t,u) > (t',u') (or (t,u) > t', t > (t',u'}) if 
and only if t > t! . This definition is sound with respect to its usage in this paper; as shown below, 
we never need to compare two odd GC ranks having the same r-rank but different /i-ranks. 

Definition 2 (GC Ranking). A GC ranking on ^ w is a function f : V — > T> GC such that: 

for every vertex v (zV, if f(v) = (2i + for some j G I, then v B(j); 

02 for every edge {v,v') G E, f(v) > f(v'). 



[IU (a) V 2 i = {v G V | v is finite in & 2 i}; 

(b) f(v) = 2i for v G V 2i ; 

(c) ^+l=^2i\V 2 i. 



\E2 (a) V 2l+1 

(b) m 

(c) y 2i+2 



- {v G V | v is F-free in ^2i+i}; 
2i + 1 for v G Vzi+i; 

■-&2i+l\V 2l+1 . 
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A vertex v is called odd (resp. even) if f(v) G [2n]° x / (resp. /(u) G [2n + l] cvcn ). A GC 
ranking / is odd if every path in @ w visits infinitely many odd vertices. Note that (|2i2p implies 
that if two adjacent odd vertices have the same r-rank, then they have the same /i-rank. As in 
Biichi complementation, if @ w admits an odd GC ranking, then every path eventually stabilizes at 
an odd GC rank (t,j), and from the stabilization point on never visits B(j)-vertices. Therefore, 
@ w is GC accepting. 

Conversely, if & w is GC accepting, then we can find a GC ranking by a series of graph trans- 
formations as in Biichi complementation. Each stage has two phases. We begin stage i with 3^ 
(Sfo = &w)' I n the ^ rs t phase, finite vertices receive even rank 2i and are removed, resulting in 
&2i+i- Thanks to GC condition, if &21+1 is n °t em Pty, then for some j G I and v G V, v is B(j)- 
free. In the second phase, those -B(j)-free vertices receive odd rank (2i + l,j) and are removed, 
producing &2i+2- This procedure repeats for all i G [0..n] unless &21 is empty. The termination 
condition is justified by width{ < ^2i+2) < width(&2i), just as before. 

Procedure 3 (GC Ranking Assignment). 

Input: a GC accepting Output: a GC ranking f. Repeat for i G [0..n] if ^2% 7^ 0- 



GU (a) V 2 i = {v G V I u is /imte in ^2*}/ 
^ /(«) = 2t for v G T/ 2i ; 



132 (a) V 2i+ i = {v eV \v is B(j)-free in & 2i +i} 
for a j G / such that B(j)-free vertices exist; 

(b) f(v) = (2i + l,j) forvGV 2l+1 ; 

(c) &2i+2=&2i+l\V2i+l. 



In ()312p . it does not matter which j G / is chosen. But this flexibility plays an important role 
in our Streett complementation construction (see Procedure [5]) . 

Lemma 2 (|12j). @ w is GC accepting if and only if£ w admits an odd GC ranking. 

We have |£> GC | = 0(nk), and hence |ft GC | = (0{nk)) n = 2°^ nk l 



Streett Complementation. Let A = (Q,Qq,'E,A,(G,B)i) be a Streett automaton. Rabin 
ranking is meant for Streett complementation. Let us first examine the simple case where k = 1, 
i.e., every path satisfies [G(l), B(l)]. Easily seen, ^S w admits a co-Biichi ranking, and hence we can 
instantiate Procedure[T]with 1Z being co-Biichi level rankings (which are also GC level rankings with 
index size 1). The only modification needed is to enforce that every path visits G(l)-vertices, which 
can be easily realized by a Biichi accepting condition (see the definition of (F') in Procedure!!]). This 
simple procedure fails for k > 1, because a path visiting a finite number of -B(j)-vertices may not 
have to visit infinitely many G(j)-vertices; it just satisfies [G(j'), B(j')] for j' ^ j. Nevertheless, if 
we could find a way to reduce the number of Rabin pairs one by one, eventually the simple scenario 
has to occur. The idea in [14J is to use GC rankings to approximate Rabin accepting behaviors step 
by step until finally obtaining the precise characterization. As a result, Rabin ranks are tuples of 
GC ranks, considerably more sophisticated than GC ranks. We first put aside the formal definition 
of Rabin rankings and show how a Rabin ranking can be obtained provided & w is Rabin accepting. 
Once again, this is done through a series of graph transformations. 

Procedure 4 (Rabin Ranking Assignment). 

Input: a Rabin accepting Output: a Rabin ranking f . Repeat for i G [0..k] if&i 7^ 0. 
^1 Assign % a GC ranking gc i+1 . 
^2 Remove all vertices v if gc i+i (v) is even. 
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3 Remove all edges (v,v') if gc i+1 (v) > gc i+1 (v'). 

^4 Remove all edges (v,v') if gc i+1 (v) is odd with index j and v is a G(j) -vertex. 

[7}5 f(v) = (gc 1 (v), . . . gc i+1 (u)} iff v is removed from &i . 

Obviously, if & w is Rabin accepting for a Rabin condition [G, B]j, then it is also GC accepting 
for the GC condition [B]j. By Lemma[2l a GC ranking gc x exists for which justifies Step (|4lip at 
stage 0. Steps (|412p - (|4i3p may break up % into a collection of graph components (in the undirected 
sense). Let C be such a component. Steps (|4l2p - (|413p ensure that vertices in C have the same odd 
rank with some index j 6 /, and hence all are -B(j)-free. Step (|4i4p . deleting all outgoing edges from 
G(j)-vertices, may further break up C into more components. In particular, any infinite path is 
destroyed (i.e., broken into a collection of finite paths) if the path satisfies [G(j), B(j)] (i.e., visiting 
infinitely many G(j)-vertices but only finitely many £>(j)-vertices). Let C' C C be a resulting 
component after Step (|414p . As a result, C should satisfy the reduced Rabin condition [G, B]nijy, 
and hence the reduced GC condition [B]j\yy. So after stage 0, £fi is composed of a collection of 
pairwise disjoint components, each of which satisfies a Rabin condition whose cardinality is at most 
k — 1. Precisely speaking, at the beginning of each stage i > 1, ^ is composed of a collection of 
pairwise disjoint components, and at Step (|4iip . gc i+1 is obtained by independently assigning each 
component in ^ a GC ranking according to the reduced GC condition the component satisfies. By 
induction, at stage i > 1, vertices in each component in ^ have been assigned the same tuple of 
odd GC ranks of length i and each component satisfies a Rabin condition whose cardinality is at 
most k — i. It follows that the procedure terminates and each vertex in & w eventually gets a tuple 
of GC ranks of length at most k + 1. Note that the last GC rank in a tuple is always an even GC 
rank (r-rank). 

Let V R denote the set of Rabin ranks of the form ((ri,i\), . . . , (r m , i m ),r m +i) (m < k). Ordering 
relations (<m,<m,>m,>m,=m) on Rabin ranks are defined to be the standard lexicographical 
extension (up to m-th component) of orderings on GC ranks. For a Rabin rank 7 of the above 
form, the index projection (or the h-projection) of 7, written Projh 7, is . . . , i m ) and the numeric 
projection (or the r -projection) of 7, written Proj r 7, is (7*1, . . . ,r m+ i). With respect to a given 
function / : V — > P R , the width of v £ V is the length of f(v), denoted by \v\f (or \v\, when 
/ is clear from the context). We say that v is odd (called happy in [14] ) if \v\ > 1 and v is a 
G(\v\ — l)-vertex. We arrive at the formal definition of Rabin rankings. 

Definition 3 (Rabin Ranking). A Rabin ranking is a function f : V — > P R satisfying the following 
conditions. 

Eli For every vertex v € V with \v\ = m + 1 > 2 and a = Projh f( v )> we have 



For every edge (v,v') € E with \v\ = m + 1, \v'\ = m' + 1 and m" = min(m,m'), we have 



(a) for i G [l..m), v G(a[i]); 



(b) for i G [l..m], v $ B(a[i]). 



(a) f(v) > m „ f(v>); 



(b) f(v) > m "+i f{v'), orv is odd. 



A Rabin ranking is odd if every path in & w visits infinitely many odd vertices. 



Lemma 3 ([3]). ^ w is Rabin accepting if and only if^ w admits an odd Rabin ranking. 
We have |£> R | = (0{nk)) k+1 and hence |ft R [ = {(0{nk)) k+1 ) n = {nk)°^ = 2 oi - nk ^ nk \ 
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4 Improved Streett Complementation 



The above construction requires 2 ( nfcl s nfc ) state blow-up [2], which is substantially larger than the 
lower bound in [3]. In the extreme case of k = 0(2 n ), the construction is double exponential in n. 
Intuitively, the larger the k, the more overlaps between B(i) 7 s and between G(i)'s (i € I). A natural 
question is: can all Rabin pairs [G(i), B(i)] independently impose behaviors on a Rabin accepting 
We showed in [2] that in Rabin complementation we can build a Streett accepting < S W for which 
no Streett pair (G(i), B(i)) is redundant. We observed the opposite in Streett complementation; 
the larger the k, the higher the correlation between infinite paths that satisfy [G, B]j. By exploiting 
this correlation, we can walk in big steps in approximating Rabin accepting behaviors using GC 
rankings. As a result, our Rabin ranks are tuples of GC ranks of length at most \i = min(n, k). This 
simple but crucial observation leads to a significant improvement on the construction complexity. 
We elaborate on this below. 

The first idea is that at Step (|4i4p in stage i, in a component C of instead of removing all 
outgoing edges from G(j)-vertices, we can remove all outgoing edges from G(j')-vertices for all f 
such that B(j') C B(j). Let J = {f £ I \ B(j') C B(j)}. Since vertices in C are B(j)-hee, they 
are also B(j')-hee for any j' 6 J. Recall that Step (|4i4p is to break all infinite paths that satisfy 
[G(j), B(j)] so that in each resulting component we have a simpler Rabin condition to satisfy. If 
an infinite path in C satisfies [G,B]j, then removing all outgoing edges from G(j')- vertices (for 
f € J) certainly serves the same purpose, and moreover, any resulting component only needs to 
satisfy a Rabin condition whose cardinality is \ J\ less than at the beginning of stage i. 

The second idea is that at Step (|4iip in stage i, we can assign special GC rankings to components 
in <Si. Recall that a GC ranking is obtained by a series of graph transformations too. In Step (1312p . 
we assign and remove B(j)-hee vertices for some j € /. In fact any fixed j G / is sufficient as 
long as -B(j)-free vertices exist. Therefore, we can choose a j such that not only i?(j)-free vertices 
exist, but also for any other j' £ /, B(j') <£. B(j), if B(j')-free vertices also exist. Intuitively, we 
prefer a j such that B(j) is minimal (with respect to set inclusion) because more vertices would 
be -B(j)-free and subject to removal. 

We refine those ideas by taking into account the history of GC rankings. In stage i, right before 
Step ()4lip . vertices in Sfj were assigned a tuple of GC ranks of length i. Consider a component 
CCJfj. No vertices in C received an even GC rank in stage i' £ [0..z), because otherwise they were 
already removed by Step (I412D in that stage. Also all vertices in £fj received the same odd GC rank in 
each stage i' € [0..i), for otherwise Step (|4i3p in stage i! would have broken the component. Now let 
((ri, ji), . . . , (ri,ji)) be the tuple that has been assigned to all vertices in C. Let B' = ^te[i-i]^(jt) 
and J' = {j' € / | B(j') C B'}. So all vertices in C are B'-iree. When we assign GC rankings for C, 
in each stage at Step (1312j) (in Procedure [3]) , we choose a j 6 I\ J' such that (1) B(j)-hee vertices 
exist, (2) B{j) B' (we say B(j) is not covered by B'), and (3) no B(j')-free vertices exist for any 
other j' G I\ J' with B' U B(f) C B' U B(j). In other words, we choose a j such that not only we 
can find B(j)-hee vertices, but also B' U B(j) minimally extends B'. Now let C be a component 
right before Step (|4i4p is taken and let {{ri,j\), . . . , <Vi+i,ii+i)} be the tuple of ranks that has been 
assigned to all vertices in C' (for the same reason as before, all vertices in C' have received the same 
sequence of odd GC ranks). Let B" = B' U B(j i+1 ) and J" = {f € / | B(f) C B"}. In Step (HH) 
we remove all outgoing edges of G(j")-vertices if B(j") C B". This deletion destroys all infinite 
paths that satisfy [G, B]jh because all vertices in C are i?"-free. Let C" be a resulting component 
and g an infinite path in C" . Then g only needs to satisfy [G, B]j\j//. 

Now let us assume that we have incorporated the above ideas into Procedure H] and obtained a 
new Rabin rank 7 = ((7*1, ji), . . . , (r m ,j m ),r m+ i)). Let a = Projh7- The non-covering condition 
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stated above requires a to satisfy: 



Vi G [l..m] B(a[i]) 2 Up^atf]), 



(3) 



which implies \a\ < n. By definition, |a| < k and so we have \a\ < /t and I7I < /i + 1. From now on 
we switch to terms fiR ranks (i.e., minimal Rabin ranks), fiK rankings, fiK level rankings and //R 
level ranks. Their precise definitions are to be given below. We define two functions Cover :/*—>• 2 1 
and Mini : I* — > 2 1 to formalize the intuition of minimal extension. Cover maps tuples of indices 
to subsets of I such that 



Note that Cover(e) = 0. Mini maps tuples of indices to subsets of I such that j G Mini(a) if and 
only if j G I \ Cover (a) and 



Mini(a) consists of choices of indices to minimally enlarge Cover (a); ties (with respect to set 
inclusion) are broken by numeric minimality (Condition ([5])). Before introducing //R ranking 
assignment, we need a new GC ranking assignment which takes a tuple of /-indices as an additional 
input. We call so obtained GC rankings (resp. GC ranks) //GC rankings (resp. //GC ranks). 

Procedure 5 (//GC Ranking Assignment). 

Input: a GC accepting a tuple of I -indices a. Output: a /uGC ranking f. 
Repeat for i G [0..n] if^ 2 i / 0- 

[5U (a) V21 = {v G V I v is finite in%?2i}; 02 (a) V21+1 = {v G V \ v is B(j)-free in 



As in GC ranking assignment, in (|5l2p there maybe more than one j such that B(j)-iree vertices 
exist, and it does not matter which one we choose. But in case Mini(a) is a singleton, we have 
a unique j at all stages, essentially synchronizing all /i-ranks in the //GC ranks obtained. This 
synchronization is crucial in our construction for parity complementation (see Section [6]). 

Procedure 6 (//R Ranking Assignment). 

Input: a Rabin accepting %. Output: a //R ranking f . Repeat for i G [0..//] if 7^ 0. 
Assign ^ a //GC ranking gc i+1 . 
Remove all vertices i/gc i+1 (t>) is even. 

05 Remove all edges (v,v') G E if gc i+1 (v) > gc i+1 (v'). 

IM4 Remove all edges (v,v') G E if v G G{t) for some t G Cover (Projh((gc 1 , . . . ,gc i+1 ))). 
El 5 f(v) = (gc 1 (f ), . . . gc i+1 (f )) iff v is removed from fy. 



Cover (a) = { j G I | B(j) C \J£ x B{a[{[) }. 



Vj' G I\ Cover(a) (j' ^ j -> B(j') U Cover(a) ^ U Cover(a)) , 
Vj' G J\ Cover(a) (/ < j -> U Cover(a) / B(j) U Cover(a)) . 



(4) 
(5) 



(b) f(v) = 2i for v G V 2i ; 

(c) ^+l=^2i\V 2 i. 
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Note that Step (|61ip actually means that Procedure [5] is called upon for every component Cc^j, 
with the corresponding a being Projh((gc 1 (t;), . . . , gCj(v))) for some v £ C (a is well-defined since 
all vertices in C have received the same sequence of /iGC ranks). It is time to formally define /iR 
ranking. Let / be a function V —> (2? GC )^ +1 . We say that v is odd if \v\ > 1 and v is a G(i)-vertex 
for some t € Cover (a[l..|v| — 1]) where a = Projh /(v). 

Definition 4 (/iR Ranking). A /iR ranking is a function f : V — > (D GC )^ +1 satisfying the following 
conditions. 

2| i For every vertex v € V with \v\ = m + 1 > 2 and a = Projh /(u), we /iaue 

(a) for i e [l..m), w G(t) /or i e Cover(a[l.i]); 

(b) for i € [l..m], v B(i) for t € Cover(a[l..i]); 
(cj fori 6 [l..m], a[i] € Mini(a[l.i)). 

For every edge (v,v ! ) € I? u>i£ra |«| = m + 1, |t/| = mf + 1 and m" = min(m, m') ; we raaue 
(W /(«) >m" /K); (fy f(v) > m "+i f{v'), orv is odd. 

A /iR ranking is odd if every infinite path in @ w visits infinitely many odd vertices. 
Lemma 4. ^ w is Rabin accepting if and only if & w admits an odd /iR ranking. 



5 Complexity 



In this section we analyze the complexity of our construction. As shown below, all complex- 
ity related notions X are also parameterized with B (besides n and k). Still, we choose to list 
some or all of them when clarity is needed. In particular, we use \X\ to abbreviate |X(n,&)| = 
m&XB \X(B, n,k)\. 

Let 2?^ R be the set of /iR ranks that can be produced by Procedure [6l Formally, T>^ = 
Df range(/) where / ranges over all possible outputs of ProcedureEl In a similar manner, we define 
TV 1 and £^ R . We have |7^ R | = |£^ R |. We note that these notions are defined differently from 
their counterparts in Section [3j due to two kinds of correlations (which we refer to as horizontal and 
vertical correlation), |£^ R | is much smaller than |p/ iGC | n (^+ 1 ). We view jC^ r as a set of n x (/i + 1) 
matrices of /uGC ranks and carry out a further simplification. Let .A/P R be a set of n x /i matrices 
obtained from £^ R by the following mapping: each n X (/i + 1) matrix M is mapped to an n x a 
matrix M' by (a) deleting from M even ranks at the end of each row, (b) changing odds rank 
of the form {2i — 1, j) to and (c) aligning each row to length [i by filling (l,0)'s. Clearly, 

|£^ R | < n n ■ |A4** |; the factor n n suffices to compensate (a), the deletion of even ranks, and (b) 
and (c) have no effect to the cardinality (for (b), z — > 2z — 1 is one-to-one from [l..n] onto [2n] odd ). 
Let M 6 be called /iR-matrices. We write Proj r M and Projh M to mean, respectively, the 

projection of M on numeric ranks (called an r-matrix) and on index ranks (called an /i-matrix). 
Let M r = Proj r -M' tR , M h = Projh -M^ R , and T> r and T> h be the sets of rows occurring in matrices 
in M r and M h , respectively. Obviously, we have \M^ R \ < \M r \ ■ \M h \ and \M h \ < {\T> h \) n . 

Example 1 (/iR-Matrix) . Let us consider a case where n = 3, k = 3, and Q = {qo,qi,q2}- Below 
we show that a /iR level rank f corresponds to a fiK-matrix M, which projects to M r and M^. 



(1,2) 
(1,2) 

:i,2) 



Q 



(1,3) 
(3,1) 
(3,1) 
/ 



4 
2 

(3,3) 



(1,2) 
(1,2) 
(1,2) 



(1,3) 
(2,1) 
(2,1) 
M 



(1,0) 
(1,0) 
(2,3) 
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1 
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CO 







1 


2 


1 
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1 
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2 
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3 : <?2> l:{go,9i} 2 : {90} 1: {90,91} 



4 : {92} 2 : {90} 3: {91,92} l:{go,?i} 2 : {go} 1 : {<2o,<Ji} 



T(3,4,£) 



r(3,5,5') 



Figure 2: Two ITS in Example [2j 



Bounding |.M |. It turns out that we only need to exploit a horizontal correlation to bound 
l-M^I. Recall that each a £ I* names a subset of Q, namely Cover(a). The idea is to order all a 
that could occur in T> h into a tree structure. Consider an unordered tree where the root is labeled 
by e and each non-root node is labeled by an index in /. With little confusion, we identify a node 
a with the path from the root to a and represent a by the sequence of indices on the path. So a 
non-root node a has a[|a|] as its label and names Cover(a). We arrive at the following important 
notion. 

Definition 5 (Increasing Tree of Sets (ITS)). An ITS T(n,k,B) is an unordered I-labeled tree 
( except the root which is labeled by e) such that 

0i A non-root node a exists in T(n,k,B) ijfVi £ [l..|a|], a[i] £ Mini(a[l..i)). 

Property ()51ip succinctly encodes three important features of ITS. First, an ITS is maximal 
in the sense that no node can be added. Second, if j3 is a direct child of a, then (3 must name at 
least one new state that has not been named by a. Third, the new contributions by j3 cannot be 
covered by contributions made by any another sibling f3' . In particular, if more than one sibling 
can make the same contribution, then the one with the smallest index is selected. It follows that 
each tuple of n, k and B uniquely determines T(n,k,B) (in the unordered sense). Note that the 
height of T(n, k, B) (the length of the longest path in T(n, k, B)) is bounded by \i. 



Example 2 (ITS). Consider n = 3, k = A, Q = {q , q!,q 2 }, B : [I. A] 2^ and B' : [1..5] 2 Q , 



and B' extends B with B'(5) = {qi}- T(3, 4, B) and T(3,5,B') are given in Figure^ For clarity, 
for each non-root node a, we also list B(a[\a\}) as the set label of a. In T(3, 4, B), neither {qo,q±} 
nor {(71,(72} can appear at height 1, because {qo,1i} covers {go} and {(71,(72} covers {(72}- The 
leftmost node at the bottom level is labeled by {q±, (72} instead of by {q 2 } due to the index minimality 
requirement. For the same reason, in T(3, 5,B'), we have nodes (2,1), (2,4,1) and (4,2,1) all 
labeled with {(70,(71}, and nodes (2,1,3) and (4,3) all labeled with {(71,(72}- 

It is easily seen that Property (|4ilcp corresponds exactly to Property (|51ip . So a one-to-one 
correspondence exists between non-root nodes in T(n,k,B) and elements in T> h (n,k, B). Let 
|T(n, k,B)\ denote the number of non-root nodes in T(n,k,B) and H(n,k) = max^ \T(n,k,B)\. 
Clearly, we have \M h \ < (H(n,k)) n . 



B(l) = {q , qi } 



B{2) = {(70} 



5(3) = {(71,(72} 



5(4) = {(72}, 



Lemma 5. H(n, k) 



2 0(fcl g fe) f 0r k = O(n) andH(n,k) = 2°( nl s n ) fork = u;(n). 
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Bounding |.M r |. Here we need to exploit both horizontal and vertical correlations. We show 
that every n x u r-matrix induces a 2^-labeled ordered tree with at most n leaves and with height 
at most \i. Such a tree is called annx/i tree. We bound \A4 r \ by counting the number of n x fi 
trees. 

Let M be an r-matrix. Since M comes from a //R level rank, M is associated with vertices at 
a level. To facilitate the discussion below, we use term states to specifically mean those vertices 
at the level where M is associated with, and use term vertices just as before. By rank i we simply 
mean a number i in M, which corresponds to the numeric fiGC rank 2i — 1. 

Let us first consider ranks in column 1 of M. A state q being ranked with an odd /uGC rank 
means that at certain stage of /iGC ranking assignment, q becomes B(j)-iree for some j G /, which 
implies that there exists an infinite path starting from q (recall that all finite vertices have been 
removed before this odd /iGC rank is assigned). If two states q, q' are ranked with different odd 
/iGC ranks, say q with (2i — 1, j) and q' with (2i' — where i > i' , then there exist two infinite 
paths g and g' such that g starts from q, g' starts from q' , and g and g' never intersect. This is due 
to the nature of /iGC ranking assignment; (2i — is assigned to some B(j)-fiee vertices only 
after those B(j')-fiee vertices with odd /iGC rank (2i' — l,f) have been removed. 

Note that it is perfectly possible that an infinite path starting from q intersects another infinite 
path starting from q'. But a maximal subset of states, all with the same rank, called a cell at 
column 1, should "own" at least one private infinite path that does not intersect the private paths 
owned by any other cells at column 1. We call a path named if it is owned by a cell. Let m' 1 ' 
be the maximum rank in column 1, and note that not all ranks in [L.m^] necessarily appear in 
column 1. But again, by the way /xGC ranking assignment is carried out, for each non-occurring 
rank, at least one private infinite path exists, which is called hidden and viewed as being owned by 
0. Easily seen now, each rank in [L.m^ 1 )] corresponds to a non-empty set of private infinite paths. 

In general, a cell at column I is a maximal subset of states, each of which is assigned the same 
tuple of ranks up to column /. Consider a cell = {qt 1 , ■ ■ ■ ,qij} at column /. Let m^ 1 ^ = 
msx{M[ii,l + 1], . . . , M[ij, I + 1]}. By the same reasoning as before, each rank in [l..m" +1 -'] 
corresponds to a non-empty set of private infinite paths. The private paths associated with rank 
M[ij*,l + 1] are owned by Sj l , +1 ^ C which is a cell at column I + 1 with rank M[ij>,l + 1] 

(S^ +1) = if no states in is mapped to M[ij>,l + 1]). Moreover, none of these paths, hidden 
or named, should intersect private paths owned by any cell at column I that is a subset of 
because states in Q \ and states in are not in the same component at stage I (the I + 1-th 
stage) in Procedure [6l Now we are ready to show how to build annx/j tree from M. 

Each node in the tree is associated with a label which is a subset of Q. The root is labeled 
with set Q. For each rank i G [l..m"], we add a child to the root and we order those children 
increasingly by the ranks associated with them. If i does not appear in column 1, the i-th child 
(from left to right) is labeled with and is a terminal node (leaf). Otherwise, the child is labeled 
with the cell at column 1 with rank i and the child is non-terminal if its height is less than \i. 
We repeat the process column by column. Each maximal at column I < fi corresponds to a 
non-terminal node at height I, from which we spawn a child for each rank in i S [L.m'''], and we 
order and label the children using the rule stated above. After processing column fj,, we obtain an 
n x fj, tree, because the number of leaves in the tree cannot exceed width(& w ) < n, which we refer 
to as the maximum width property (MWP). Now we call an n x fi tree a TOP (Tree of Ordered 
Partitions) and let T r (n,k) denote the set of TOPs. We have \M r \ < |T r (n, k)\. 

Example 3 (TOP). Four 3x3 matrices M1-M4 and their corresponding tree representations T1-T4 
are given in Figured M1-M3 obey MWP and hence T±-T3 are TOPs. T4 is not a TOP because it 
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Figure 3: Four 3x3 matrices and their corresponding tree representations in Example [3) 
has more than 3 leaves. 

Lemma 6 (Numeric Bound). |T r (n, k)\ = 2°( nl s n ). 

Since |7^ R | < n n ■ |A^ R |, \M^\ < \M r \ ■ \M h \, \M r \ < \T r {n,k)\, and \M h \ < {H{n,k)) n , 
by Lemmas [5] and [6j we have 

Theorem 1 (Streett Upper Bound). Streett complementation is 2°( nlgn+nfcl s fc ) for k = 0(n) and 

2 0(n 2 lgn) f Qr f, _ u ( n y 

Note that we put bounds in the form 2°^ just for simplicity. Even for a small k (i.e. k = 
0(n)), our upper bound is substantially smaller than the current best one (nk)°( nk \ established 
by respective constructions in (8J l22"j [T4"t I19| . Easily seen from the proofs of Lemmas [5] and El 
our upper bound is in fact n°( n ' • k°( nk ^ when k = 0(n). Also note that Lemma [6] is crucial in 
tightening parity complementation. 

6 Parity Complementation 

Parity automata is a special kind of Streett automata where a Streett condition (G, B)j is aug- 
mented with the so-called Rabin chain condition B(l) C G(l) C • • • C B{k) C G{k). Now the short 
length of juR ranks is not enough to give us a better bound, because we already have k < \_(n+l) /2j . 
Nevertheless, the Rabin chain condition makes the GC condition [B]j degenerate to the CB condi- 
tion [5(1)], because being 5(l)-free is equivalent to being B(i)-£ree for some i € J. This coincides 
with the way Mini works. Intuitively, Mini synchronizes all components at a stage of [iR ranking 
assignment. In the first stage of /uR ranking assignment, in Step (|4lip . Mini makes every vertex get 
the /i-rank 1, though vertices may get different r-ranks. After disabling G(l) vertices (by deleting 
all outgoing edges from them in Step (|4l4p ). we have a collection of components satisfying parity 
condition {G, BW.fci- Then in the second stage of //R ranking assignment, Mini gives every vertex 
the /i-rank 2. Repeating this process, the /i-projection of a final ;uR rank is just (1, . . . , m) for some 
m £ [1..&], which is completely redundant, because the only useful information (having length m) 
is already encoded by the corresponding r-projection. As a consequence, /i-matrices contribute 
nothing to the complexity. A customized construction for parity complementation is given in the 
appendix. 

Theorem 2 (Parity Upper Bound). Parity complementation is in 
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This bound matches the lower bound of Biichi complementation, and hence it is tight as Biichi 
automata are a subclass of parity automata. To the best of our knowledge, the previous best upper 
bound is 2°( nfcl s n ), which can be easily inferred from [TJ] by treating parity automata as Rabin 
automata. 

7 Concluding Remarks 

In this paper we improved Kupferman and Vardi's construction and obtained tight upper bounds 
for Streett and parity complementation (with respect to the 2 e ^ asymptotic notation). Figured] 
in the appendix rounds up the complementation complexities for w-automata of common types. 

Our inquiry also leads to some unexpected outcomes, which we believe, would help understand 
the strength and weakness of different types of w-automata in modeling and specifying system 
behaviors. 

1. Parity complementation has the same asymptotical bound as Biichi complementation while 
parity automata have richer and more elegant acceptance conditions than Biichi automata. 

2. Streett automata are exponentially more succinct than Biichi automata while Rabin au- 
tomata are not. On the other hand, Streett complementation is much easier than Rabin 
complementation when k is large (i.e., k = ui{n)). In the extreme case where k = 0(2 n ) and 
N = Q(nk) (the automata size), Streett complementation is in 0(N& N ) = 0(2fc N ) while 
Rabin complementation is still in 2^ N \ 

Further investigation on Streett and parity complementation is desired as exponential gaps can 
hide in the asymptotical notations of the form 2®^) . The situation is different from that of Biichi 
where the best lower and upper bounds have been shown polynomially close. 

We think that ITS and TOP characterize intrinsic combinatorial properties on run graphs with 
universal Rabin conditions. Interesting questions remain for further investigation. What would 
be the counterparts for run graphs with existential Streett conditions? The discovery of such 
combinatorial properties might help us understand the complexity of Streett determinization, for 
which there exists a huge gap between the current lower bound 2^ n lgn ) [3] and upper bound 
20(nkignk) jjgj w h en — u)(n). Also of theoretical interest is whether there exists a type of 
w-automata whose determinization is considerably harder than complementation. In the case of 
Biichi, the two operations were both proved to be in 2 e, ( nlgn ). 
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A Parity Complementation Construction 

Parity ranking is used for parity complementation. Let % be a parity accepting A-graph. The 
following procedure assign a parity ranking to 

Procedure 7 (Parity Ranking Assignment). 

Input: a parity accepting Output: a parity ranking f. Repeat for i € [0..k] if 7^ 0. 

Assign a co-Biichi ranking cbj + i with respect to the co-Biichi condition [B(i + 1)]. 

^2 Remove all vertices v € V if cbi+i(v) is even. 

0.5 Remove all edges (v,v') € E if cbi + i(v) > cbj + i(V). 

^4 Remove all edges (v,v') € E if v € G(i + 1). 

0.5 f(v) = (cbi(v), . . . cbj + i(u)) iff v is removed from 

Let X> p denote the set of parity ranks, a set of tuples of co-Biichi ranks of length at most k + 1, 
which can be produced by Procedure [71 Similar as before, let \v\ be the width of v with respect to 
a given function / : V — > (D CB ) fc+1 . We say that v is odd if \v\ > 1 and i> € G(|v| — 1). 

Definition 6 (Parity Ranking). A parity ranking is a function f : V —> (p CB ) fc + 1 satisfying the 
following conditions. 

For every vertex v € V with \v\ = m + 1 > 2, we have v B{m). 

For every edge (v,v') S E with \v\ = m + 1, \v'\ = m! + 1 and m" = min(m, m'), we have 

(a) f(v) > m „ f(v'). 

(b) f(v) > m "+i fW), orv is odd. 

A parity ranking is odd with respect to & w if every infinite path in & w visits infinitely many 
odd vertices. 

Lemma 7. <£ w is parity accepting if and only if ^ w admits a parity ranking. 

B Proofs 

We split Lemma 0] to Lemmas 1101 and [TT1 Lemma [10] requires the following two additional lemmas. 

Lemma 8. Let g be an infinite path in that admits a /xR ranking f. Then for any i £ N, 
/(<?(»)) >i /(*?(* + !))• 

Proof. Let i € N, |f?(i)l = m + 1, \g(i + 1)| = rnf + 1 and m" = min(m, m'). By Property (Hl2bp . 
f(Q{i)) >m"+i /(£?(*+!)) unless g(i) is odd. If g(i) is not odd, then f(g(i)) > m "+i implies 
f (g(i))[l] > f(g(i + 1))[1]. But if g(i) is odd, then by definition m" > 1. Now by Property (|4T2a) . 
we still have > /(*?(» + 1))[1], that is >i /(g(t + 1)). □ 

Lemma 9. If£ admits a /iR ranking f , then any infinite path in has only finitely many vertices 
of width 1 . 
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Proof. Let g be an infinite path that contains infinitely many vertices of width 1. By Lemma [8] we 
have 

/(e(o))>i/GKi))>i/0?(2))>i... (6) 

Because / is a /iR ranking for g has infinitely many odd vertices. Since odd vertices have 
width greater than 1, g has to contain infinitely many edges between vertices of width > 1 and 
vertices of width 1. Then in the above sequence, infinitely many relations are >i, a contradiction 
to well-foundedness. □ 

Lemma 10. If admits a [iR ranking f, then all paths of£ satisfy [G,B]j. 

Proof. Let / be a //R ranking for and g an infinite path in . By Lemma [9l g contains a suffix 
in which all vertices have width > 1. Let m" be such that m" + 1 is the minimum width of vertices 
in g that appears infinitely often. So m" > 1. 

We show that there exist infinitely many odd vertices with width m" + 1. Suppose the opposite. 
Since there are infinitely many odd vertices and m" + 1 is the minimum width of vertices occurring 
infinitely often, from some point on in g, all odd vertices (there are infinitely many) have width 
> m" + 1. By Property (|4[2bp . for some jo > 0, we have an infinite non- increasing sequence 

ttatio + 1)) fieUo + 2)) (7) 

However, the projection of m" + 1-th positions of the sequence contains infinitely many even GC 
ranks (from vertices of width m" + 1) as well as odd GC ranks (from vertices of width > m" + 1), 
which together with ([8]), contradicts well-foundedness. 

By Property (|4i2ap . for some j\ > 0, we have an infinite non-increasing sequence 

fieUi)) > m » f(e(h + 1)) >m» /(eO'i + 2)) > m » • • • (8) 

which further implies that from some > ji, we have 

/(f?(j 2 )) =m» f(e(h + 1)) =m» f(e(j2 + 2)) =m" ' ' ' ■ (9) 

By Property ()4ilap . for any vertex v after level ji-, v B(t) for any t E Cover(a[l..m"]) where 
a = Projh/(u). Because there exists infinitely many j'3 > j% such that g(js) is odd and |^(j3)| = 
m" + 1, by definition of oddness, we have infinitely many vertex v' such that v' € G(t) for some 
t G Cover(a[l..m"]). Because Cover(a[l..m"]) is finite, there must be some t' such that G(t') is 
visited infinitely often by g. Thus, g satisfies [G, B]j, in particular, the condition [G(t'), B(t')]. □ 

Lemma 11. Let £f be a A-graph that satisfy [G,B]i. Then & admits a fiR ranking. 

Proof. Let / be the function produced by Procedure We show that all properties in Definition U] 
are satisfied by this / and any infinite path in & w visits odd vertices infinitely often. 

Property (|4iip . Let v £ V be a vertex with width m+1 and f(v) = ({ri, i%) . . . , {r m ,i m ),r m+ i}. 
Let a = Projh f(v) = (ii, . . . , i m ). We have m > 1. 

Property (|4llbp . The fact that v get odd GC ranks in stage 0, . . . , m — 1 means that v B(ctj) 
for any j € [l..m]. This implies for any j G [l..m], v B(t) for any t G Cover(a[l..j]). 

Property (|4ilap . If m = 1, then this property holds trivially. Suppose m > 2, and for some 
j G [l..m — 1], v G G(t) for some t G Cover (a[l..j]). Due to Property (jUTb]), we have v G" B(t). 
Then Step (|614p in stage j — 1 (note that stage numbering starts at and index numbering starts 
at 1) will remove all outgoing edges of v, rendering v as a finite vertex in So in stage j, v 
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will get an even GC ranks. Since j € [l..m — 1], for some f £ [2..m], a[j'} is an even GC rank, 
contradicting the definition of a. Therefore, Property (|4l la|) follows. 

Property (|411cp . At stage i (for i < m), v obtains a GC ranking with respect to [G, -B]/\j 
where J = Cover(a[l..i]). Therefore, ai + i £ J and B(ai+i) % Ut<=jB(t), where \JtejB(t) is equal 
to U* =1 i?(a[j]) = Cover(a[l..i]). This says that Mini(a[l..i]) 7^ 0. The property then follows from 
the way we carry out minimal GC ranking (Step (|512p in Procedure [5]) . 

Property (|4l2p . Let v, v' G V and (v, v') € E. Let m, m! be such that = m + 1, \v'\ = m! + 1 
and m" = min(m, m'). Property (|4i2ap trivially holds for m" = 1. Property (|4[2bp holds for m" = 1 
due to LemmaO Now assume that m" > 1. Let 9 be the maximum number such that (v, v') exists 
in the same component in By Definition [2j we have f(v)[i] > f(v')[i] for all i € [1..8 + 1]. 

Case 1: 9 = m". In this case Property (|4i2p is immediate, because by Property (|2i2p . /(u)[i] > 
/(v')[i] (for any i G [l..m" + 1]), which implies /(w) > m "+i f(v'). 

Case 2: 9 < m" — 1. Then t> and v' are in different components in So (v,v') must 

be removed at stage 9. Since 9 < m" , both + 1] and f(v')[9 + 1] are odd, and therefore 

(v, v') cannot be removed by Step (I612p . Nor can it be removed by Step (I614p . because otherwise v 
becomes finite in Sfg+i and removed at stage + 1 < m", and hence = 9 + 2 < m" < m" + 1, 

a contradiction. The only possibility left is that (v,v') is removed by Step ()613p . Then we have 
f(v)[9 + 1] > /(«0[^ + !]• We already have > /(«')[«] for a11 * 6 I 1 - 6 * + 1]. and 9 + 1 < 

Therefore, f(v) > m " f{ v ')- We are done with Property (|4i2p . 

Case 3: 9 = m" — 1. In this case, Property (I4l2ap is immediate, because f(v)[i] > f(v')[i] 
(i S [l..m"]) implies f(v) > m » f(v'). Property ()4l2b[) follows immediately if f(v) > m " f( v ')- So we 
assume f(v) = m » f(v'). As before, (v,v'} cannot be removed by Step (I612p because both f(v)[9] 
and f(v')[9] are odd. But now {v,v') cannot be removed by Step (|613p . for otherwise we have 
f(v)[9 + l] > f(v')[9 + l], contradicting the assumption f(v) = m " f(v'). Therefore, (v,v'} has to be 
removed by Step ()614p . which implies that \v\ = m" + 1 and v G G(t) for some t E Cover(a[l..m"]) 
(where a = Projh f(v)), that is, v is odd. 

What is left is to show that any infinite path in & w visits odd vertices infinitely often. Suppose 
the opposite. Then there must exist an infinite path that visits no odd vertices. Let g be such a 
path. Let m be such that m + 1 is the minimum width of vertices that appears infinitely often in 
g. We have m > 1 because of Lemma [9l Also g must have a suffix in which all vertices have width 
no less than m + 1. By Property (j4l2bp . for some j > 0, we have 

f(g(j)) >m+l f(g(j + 1)) >rn+l f (Q{j + 2)) > m+ l • • • , 

and hence for some j' > j, we have 

f(g(j')) = m+1 f(g(f + 1)) = m+1 f(g(f + 2)) = m+1 ■■■ . 

Since vertices with width m + 1 appears infinitely often in g, f(g(j'))[m + 1] must be an even 
GC rank, which means there is no vertex with width greater than m + 1 from g(j') on, and for 
any vertex j" > j' , f(g(j"))[m + 1] is an even GC rank. Let g' denote this suffix starting from 
g(j'). We claim that there must be infinitely many i such that edges (g'(i), g'(i + 1)) do not exist 
in the same component C in 5f m . Suppose otherwise, let g" be the suffix of g' such that for any 
i > 0, (g"(i), g"(i + 1)) appear in the same component in §f m . Let f[m + 1] denote the (m + l)-th 
projection of /. We have 

f[m + l](g"(0)) = f[m + l](g"(l)) = f[m + l](g"(2)) = ■■■. 

Although f[m + 1] in general may not be a GC ranking for Sf m , f[m + 1], when restricted to a C 
component in & m , is indeed a GC ranking for C. So if all g"(i) (i > 0) are in the same component 
C, then Lemma [2] is violated because g" is a path on which all vertices have even GC ranks. 
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Now let us assume that for infinitely many i, (g'(i), g'(i + 1)} is removed at stage mi for some 
mi < m. We have three cases to analyze. 

Case 1: For infinitely many i, {g'(i),g'(i + 1)) is removed at stage mi by Step ()612p . This is 
impossible because both f(g'(i))[mi] and f(g'(i + l))[mi] are odd. 

Case 2: For infinitely many i, {g'(i),g'(i + 1)) is removed at stage mi by Step (|6l3p . This is 
also impossible as f{g'{i))[m\\ > f{g'(i + l))[mi] contradicts f(g'(i)) = m f(g'(i + !))• 

Case 3: For infinitely many i, (g'(i), g'(i+l)) is removed at stage mi by Step (|6l4p . If mi < m— 1. 
Then for some i* in those infinitely many i's, |f/(i*)| = mi + 1 < m, contradicting the assumption 
that all vertices in g' have width m + 1. So mi = m — 1. The removal of (g'(i),g'(i + 1)) by 
Step (|614p is due to g'(i) G G(t) for some t G Cover(a[l..m]) where a = Projh f(g'(i)). Recall that 
we already have m > 1 due to LemmaEl They together just say that g'(i) is odd. Because we have 
infinitely many such i, we have infinitely many odd vertices in g' , and therefore in g. □ 

Lemma ED H(n, k) = 2°( fclgfc ) for k = 0{n) and H(n, k) = 2°( nlgn ) for k = uj(n). 

Proof. Recall that for fixed n, k and B : / — » 2®, T(n,k,B) is uniquely determined. Also note 
that the height of T(n, k, B) is bounded by fi = min(n, k) and the maximum branching factor is 
bounded by k. We have two cases to consider. 

1. k = O(n). In this case we have [x = 0(k). Therefore, we have 

\T(n,k,B)\ <J2 k * </iF = 2 lg ^ lgfc = 2°( fclgA; ). 

8=1 

Since B is chosen arbitrarily, we have H(n,k) = 2°( fcl & fc ). 

2. k = u)(n). Assume k > n > 2. Let B' : I' — > 2® where I' = [l..k'] be an extension of B such 
that range(-B') contains all singletons from Q. Formally, 

Vi G [l..k] B'{i) = B(i) , Vq G Q {q} G range( J B / ) . 

By Lemma [T2| we assume without loss of generality that B'(i) = {<7i_i} for i G [l..n]. Due 
to existence of all singletons, the minimal extension at each node is always done by adding 
singletons, that is, for any index sequence a, Mini(a) C [l..n]. Therefore, each nonempty 
path in T(n,k',B') corresponds to a nonempty prefix of a permutation of [l..n] and vice 
versa. All leaves of T(n,k' , B') are at height n, and T(n,k' , B') has exactly n! leaves and 
exactly n! internal nodes at height n — 1. Also, each node at height j < n — 1 has at least 
two children, which implies that the total number of nodes at height j < n — 1 is bounded 
by n!. By Lemma \13\ we have 

\T(n,k,B)\ < \T(n,k',B')\ < 3n! = 2°^ n \ 
As B is chosen arbitrarily, we have H(n,k) = 2°( nlgn ). □ 

Lemma 12. Let B : I — > 2® , B' : I — > 2® be two injective functions such that range(-B) = 
range(-B'). Then \T(n,k,B)\ = \T(n,k,B')\. 

Proof. The condition range(-B) = range(-B') means that B and B 1 just name subsets of Q differently. 
We extend B, B' to functions from I* to 2® such that for a G J*, 

\a\ \a\ 

B(a) = [j B(a[i]) , B'(a) = \J B'(a[i\) . 

i=l i=i 
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By Definition [5l children of a node a in an ITS is completely determined by B(a). So a node 
a in T(n,k,B) has the same number of children as a node a' in T(n,k,B') if B(a) = B'(a'). 
Moreover, if a.\, . . . , ctj are children of a and a^, . . . , a'j are children of a' , Then S(qi), . . . , B(aj) 
are just a permutation of B' ((%[),..., B' (a'j) . By induction on tree height, there is a one-to- 
one correspondence between nodes in T(n,k,B) and nodes in T(n,k, B'). Thus \T(n,k, B)\ = 
\T{n,k,B')\. □ 

Lemma 13. Let T(n, k, B) and T(n, k', B') be two ITS such that B' extends B by naming a 
singleton that B does not name. Then |T(n, k,B)\ < \T(n,k' , B')\. 

Proof. It suffices to show that \T(n,k,B)\ < \T(n, k' , B')\ when k' = k+l, V = [l..k'], B'{i) = B(i) 
for i £ I and B'(k+1) names a new singleton. Without loss of generality we assume B'(k+1) = {qo}. 
We show a tree transformation that turns T(n, k, B) into T(n, k + l, B'). 

Recall that labels on the path from the root to a node a is in this order: e, a[l], . . . , a[|a|]. Let T a 
denote the subtree rooted at a. We say that a state q G Q is named by a if q E B(a) = Ui=i -^( a H)- 
We define a tree transformation 9 such that 9{T a ) is as follows. 

1. q e B(a). Then 6(T a ) = T a . 

2. qo B(a). Let ai, . . . , a/ list all children of a, where each of a±, . . . ,aj names go, but none 
of cty+i, . . . , ai does. Formally, 

q £B( ai ) (i G > 0) , 

go0^(ai) (iG[3" + M,j,J>0). 

(a) (3i G -B(a) U {go} = B(a) U B{a{). Then we must have j = 1. Let 9(T a ) be the 
tree obtained from T a by replacing the label of a\ by k + 1. 

(b) (Vi G £(a) U {g } C S(a) U5(aj). Let 6>(T a ) be the tree obtained from T a by the 
following procedure. 

i. Add to a a new child (5 labeled with k + l, i.e., (3 = a ■ (k + 1). 

ii. Remove subtrees T ai , . . . , T a . from a and make them children of /?. 
hi. Add to f3 I — j new leaves labeled with ay + i[[aj + i[], . . . , cki [|ck/ |] . 

iv. Grow every new leaf into a full ITS using Mini with respect to n, k' and B' . 

In any case, 9{T a ) is an ITS with root labeled with a[|a[]. It is clear from the above procedure 
that |#(T a )| > \T a \. Now we define such that Q(T) is the tree obtained from T by applying 9 
on T level by level, from top to bottom. Example H] shows such a transformation. It is not hard to 
verify that T{n,k',B') = @(T(n,k,B)). Therefore, we have \T{n,k,B)\ < \T(n,k',B')\. □ 

Example 4. Let us revisit Example^ and see how T(3,3,B) is transformed to T(3,4, B') via 0. 
Applying 9 at the root of T(3, 3, B) we have T\: 



5 : {qi} 2 : {g„} 4 : {q 2 } 

2 : {qo} 4 : {q 2 } 1 : {q , 9l } 4 : {q 2 } 3 : {q lt g 2 } 2 : {q } 
•4: fe} 2:{g (1 } 3:{gi,g 2 } l:{go.9i} 2 : {g } l:{g ,9l} 
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Applying 8 at nodes (2) and (4) in T\, we have T2: 



5 : {qi} 



2 : {go} 



4 : {g 2 } 



2: {go} 4:{g 2 } 1 : { 9l } 4 : {g 2 } 3 : {q,} 2 : {g } 

I I I I I 

4:{g 2 } 2: {g } 3:{gi,g 2 } 1 : {?o,«l} 2 : {g } l:{g ,gi} 



Applying 6 at nodes (2,4) and (4,2) in Ti, we have T3: 



5: {qi} 



2 : {go} 



4 : {g 2 } 



2 : {go} 4 : {g 2 } 1 : { qi } 4 : {g 2 } 3 : {gi} 2 : {g } 
4:{g 2 } 2: {go} 3:{gi,g 2 } 1 : 2 : {g } 1 : { ?1 } 

^4nd no more application of 9 is possible. It is not hard to verify that T3 = T(3,4,B'). 
Lemma [6] (Numeric Bound). \T r (n, k)\ = 2°( nl § n ). 

Proof. Let T(e, I) denote the number of ordered trees with e edges and I leaves. T(e, I) are called 
Narayana numbers, which for e, I > 1, assume the following closed form |18l 14]: 



T(e,l) 



e \l) \l - 1 



A TOP has at most n leaves and at most n x fi edges. The labels of internal nodes in a TOP are 
all determined by the labels of leaves. The number of labels on I leaves is bounded by l n , which 
corresponds to the number of functions from Q to [1../]. Therefore we have 



n-fJ, min(n,e) 



|T(n,fc)|<X; Yl T(e,l)-l n <n 3 -T(n 2 ,n).n n <n( n )( J 

e=l 1=1 K " ' v " 



n 20(«lgn) 



□ 



23 



